<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>节流和防抖</title>
</head>

<body>
    <button id="btn1" onclick="sendInfo()">节流</button>
    <button id="btn2">防抖</button>
    <script>
        /* 节流函数：throttle fn: 要被节流的函数 delay：规定的时间 */
        function throttle(fn, delay) {
            // 记录上一次触发的时间
            var lasttime = 0;
            // 通过闭包的方式使用lasttime变量，每次都是上次的时间
            return function() {
                // 
                var nowtime = Date.now();
                if (nowtime - lasttime > delay) {
                    // 修正this函数问题
                    fn.call(this);
                    // 同步时间
                    lasttime = nowtime;
                }
            }
        }

        function handle() {
            console.log((new Date).toTimeString());
        }
        // const btn1 = document.getElementById("btn1")
        // btn1.addEventListener("click", throttle(handle, 6000));
        var sendInfo = throttle(handle, 1000);


        /**
         * 防抖函数
         */
        function debounce(fn, delay) {
            var timer = null;
            return function() {
                clearTimeout(timer);
                timer = setTimeout(function() {
                    fn.call(this);
                }, delay);
            }
        }
        document.getElementById('btn2').onclick = debounce(function() {
            console.log("按钮被点击了" + new Date().toTimeString());
        }, 1000)
    </script>
</body>

</html>